# Serial Peripheral Interface (SPI)

Implementation using Verilog HDL

Report

# **Table of Contents**

| Introduction                          | 2  |
|---------------------------------------|----|
| Technical Background                  | 3  |
| Verilog Implementation                | 4  |
| Simulation & Testbench                | 6  |
| Results                               | 8  |
| Conclusion                            | 10 |
| References                            | 11 |
|                                       |    |
| Table of Figures                      |    |
| Figure 1 – Master-Slave Data Exchange | 3  |
| Figure 2 – Slave's Module Code        | 4  |
| Figure 3 – Master's State Diagram     | 5  |
| Figure 4 – Master's Module Code       | 5  |
| Figure 5 – Testbench Code             | 7  |
| Figure 6 – Top Level Schematic        | 7  |
| Figure 7 – Results Waveform           | 8  |
| Figure 8 – Slave's RTL Schematic      | 9  |
| Figure 9 – Master's RTL Schematic     | 9  |

# Introduction

**Serial Peripheral Interface (SPI)** is a widely used synchronous serial communication protocol, commonly used in embedded systems to connect microcontrollers with peripheral devices such as sensors, memory chips and displays unlike asynchronous protocols SPI operates with a shared clock signal enabling faster and more reliable data transfer.

SPI is valued for its simplicity and high speed performance compared to other serial protocols while I2C supports multi master configurations and address based communication it trades off speed and complexity UART is asynchronous and good for long distance data exchange but lacks SPI s simultaneous full duplex transmission SPI s 4 wire design (MOSI, MISO, SCLK and CS) makes it efficient for short range and high speed data exchange where low latency is essential.

SPI play a significant role in system on chip architectures where integration of processors, memory, and peripherals requires fast and predictable communication interfaces. SPI is used to connect digital sensors, external flash memory, and configuration interfaces within SOCs especially where minimal overhead and timing are critical.

**The objective** is to design and simulate a verilog based SPI system consisting of both master and slave modules. through this implementation, we aim to reinforce understanding of digital design principles including finite state machines (FSM), timing control, and serial data exchange. by simulating the design in vivado the functionality of the system can be verified under realistic hardware conditions.

# **Technical Background (SPI)**

The Serial Peripheral Interface (SPI) enables fast and full-duplex data exchange between a master device and one or more slave devices. Its widely adopted in digital systems where reliability, speed, and low communication are essential.

SPI communication is based on 4 signals:

MOSI (Master Out, Slave In) carries data from the master to the slave.

MISO (Master In, Slave Out) carries data from the slave to the master.

SCLK (Serial Clock) generated by the master to synchronize the data transmission.

CS (Chip Select) activated by the master to select which slave should respond.

the master starts communication by pulling the CS line low, activating the target slave. Then using the clock signal (SCLK) it controls the timing of data exchange sending bits via MOSI and simultaneously receiving bits via MISO. Each transfer is typically 8 bits long. (other sizes are possible depending on the implementation).



Figure 1

SPI operates using different clocking modes, determined by clock polarity (CPOL) and clock phase (CPHA). These modes define whether data is sampled or changed on rising or falling edges of SCLK. **Mode 0** is used In this project, the clock idles low, data changes on the falling edge, and is sampled on the rising edge.

# **Verilog Implementation**

The design contains two main components the **SPI Master module** which controls the transmission process and the **SPI Slave module** which receives and processes incoming data. each module is designed to follow standard SPI protocol characteristics such as clock synchronization, chip select control, and bit data transfer.

### 1) SPI Slave Module

The slave module is responsible for capturing incoming bits on the mosi line and assembling them into a full byte. it uses a shift register and counts the number of bits received the slave also sends data back to the master on the miso line responding to clock edges following the SPI protocol.

```
module spi slave(
    input [7:0] data_to_send,
    output reg miso,
    output reg [7:0] received_data
    reg [2:0] bit counter :
    reg [7:0] shift_reg ;
    always@(negedge cs) // when selected by the master
        shift_reg <= data_to_send; // loads the data to be sent
        miso <= data_to_send[0];
       bit_counter <= 3'd7;
                                  // intialises the counter
    always@(posedge sclk) // at sclk's positive edge the slave samples data from the mosi (mode 0)
     begin
        shift_reg <= {mosi,shift_reg[7:1]}; //loads data from the mosi into the shift register</pre>
        shift reg <= shift reg;
    always@(negedge sclk)
    begin
       if (cs == 0)
        begin
         miso <= shift_reg[0]; // loads LSB to the miso line
            if (bit_counter !=0)
            bit_counter <= bit_counter -1 ;
else if (bit_counter == 0)</pre>
              received data <= shift reg;
              miso <= 1'bz ;
             end
       miso <= 1'bz ; // so that it doesn't drive the mosi line when it's not selected
   end
endmodule
```

Figure 2

### 2) SPI Master Module

The master module is a finite state machine that generates the serial clock (sclk) and activates the chip select signal (cs) then transmits data over the mosi line. It also reads incoming data from the miso line.



Figure 3

```
module spi_master(
   imput clk, // system clock
   imput clk, // system clock
   imput cleet,
   imput (1:0) slave_select,
   imput (1:0) slave_select,
   imput (1:0) slave_select,
   imput miso,
   output reg (3:0) cs ,
   output reg (3:0) cs ,
   output reg (3:0) cs ,
   output reg mosi,
   output reg mosi,
   output reg sole,
   output reg file) received_data,
   output reg [7:0] received_data,
   output reg [7:0] shift_reg;
   reg [7:0] shift_reg (received_data,
   output reg shift_reg[7:1]); // rising edge (master reads from the miso line) mode 0
   always@focedge = cll)
   shift_reg = (miso,shift_reg[7:1]); // rising edge (master reads from the miso line) mode 0
   endmodule
```

Figure 4

# **Simulation & Testbench**

To verify the functionality of the SPI system a testbench module spi\_tb was made. The simulation was targeting the verification of signal flow between the master and slave modules, the timing of transactions and the data exchange.

#### **Testbench:**

The testbench simulates a basic SPI data exchange between the master and a selected slave.

# **Simulation Steps**

#### 1. Reset and Initialization

- The system is reset for 20ns
- clk\_tb toggles every 10ns to create a 100MHz clock

### 2. Starting exchange

- start\_tb is used to start the SPI communication
- Slave 0 is selected by the slave\_sel\_tb
- Data bytes are loaded to mdata\_tb and sdata\_tb

#### 3. Data Transfer

- SPI master transmitss mdata\_tb via mosi
- Slave samples bits on rising/falling edges of sclk
- Slave responds via miso with sdata\_tb

#### 4. Output

- Master captures received byte in mreceived\_tb
- Slaves outputs received byte in sreceived\_tb
- done\_tb indicates transaction completion
- then the data exchange is repeated with another slave

#### Testbench Code

Figure 5

### Top Level Schematic



Figure 6

# **Results**

The SPI communication system was simulated using the spi\_tb testbench. the master and the slaves modules performed synchronized data exchange over the mosi and miso lines by the system clock (clk\_tb) and serial clock (sclk\_tb). The results waveform:



Figure 7

These results confirm correct bit shifting and proper data capture by the master (mreceived\_tb) and slaves (sreceived\_tb) and module followed SPI mode 0 behavior.

# **RTL Schematics**

# Slave's schematic



Figure 8

# Master's schematic



Figure 9

# Conclusion

This project built and tested an SPI communication system using Verilog. the results showed that the master and slave modules worked well together sending and receiving data with accurate timing that followed standard SPI rules. The design used finite state machines and clear module connections, making it easy to follow and reliable.

The system can handle multiple slave devices thanks to the chip select feature. It can also be improved with error detection like checking for missing data or timing problems to make it even more dependable.

even though it follows standard SPI behaviorr the code was written from scratch. This gave full control over how it works and makes it flexible for upgrades or use in bigger systems.

# References

- All About Circuits (SPI Protocol Explained) Link
- Brock J. Lameres (Quick Start Guide to Verilog) Link